

香港中文大學

The Chinese University of Hong Kong

# CSCI2510 Computer Organization Lecture 10: Control Unit and Instruction Encoding

# Ming-Chang YANG

mcyang@cse.cuhk.edu.hk

COMPUTER ORGANIZATIO



Reading: Chap. 7.4~7.5 (5th Ed.)

### **Recall: Components of a Processor**





### Outline



- Control Signal Generation
  - 1) Hard-wired Control
  - 2) Micro-programmed Control

Machine Instruction Encoding

# **Control Signal Generation**



- The processor must have some means to generate the control signals for instruction execution:
  - 1) Hard-wired control
  - 2) Micro-programmed control
- Every control signals (e.g., PC-out, MDR-in, ADD, SUB, ...) are switched on (active) and off (inactive) at suitable time.
  - The time duration is determined by the clock.

# 1) Hard-wired Control

- Hard-wired Control: The combinational logic gates are used to determine the sequence of control signals:
  - A counter is used keep track of the control steps.
  - Control signals are functions of the IR, external inputs and condition codes
  - The control signals are generated at the right time (i.e., control step).





## 1) Hard-wired Control (Cont'd)



#### • A simplified example:



## 1) Hard-wired Control (Cont'd)





https://people.cs.clemson.edu/~mark/uprog.html

## **Class Exercise 10.1**

| Student | <b>ID</b> |
|---------|-----------|
| Name:   |           |

Date:

- The control sequences of different instructions may consist of a different number of steps.
  - For example, the load instruction is composed of 6 steps (3 for the fetch, 1 for the decode, and 3 for the execution).
- Can you tell how many control steps are required for the other three instructions (i.e., add, store, and branch) in the given simplified hard-wired control?

### **Class Exercise 10.1**



#### • A simplified example:



# 1) Hard-wired Control (Cont'd)



- The wiring of the logic gates for control signal generation is fixed.
  - Simple signal:
    - PC-out = T0
  - Complicated signal :
    - MDR-inE = ((IR == ADD) and ((T2) or (T5))) or ((IR == SUB) and ((T2) or (T5))) or ... CarryFlag or ... and ... or ... and ... and ...
- The hard-wired control can operate at high speed.
- However, the hard-wired control has little flexibility.
   It can only implement instruction set of limited complexity.

# 2) Micro-programmed Control



- The control signals are generated by a micro-program.
- Every line is a control word.
- Micro-programs are stored in a special memory (control store).



- Z<sub>out</sub>,PC<sub>in</sub>,Y<sub>in</sub>,WMF C,MDR<sub>inE</sub>
- 3 MDR<sub>out</sub>, IR<sub>in</sub>
- 4 R3<sub>out</sub> , MAR <sub>in</sub> , Read

Zout, R1<sub>in</sub>, End

- R1<sub>out</sub>,Y<sub>in</sub>,WMF C,MDR<sub>inE</sub>
- MDR <sub>out</sub> , SelectY, Add, Z<sub>in</sub> , B<sub>in</sub>

|         | Micro | -<br>ction | ••   | PC in | PC out | MAR in | Read | MDR out | IR in | Y in | Select | Add | Zin | Z out | R1 <sub>out</sub> | R1 in | R3out | WMFC | End | B <sub>in</sub> | MDR <sub>inE</sub> |
|---------|-------|------------|------|-------|--------|--------|------|---------|-------|------|--------|-----|-----|-------|-------------------|-------|-------|------|-----|-----------------|--------------------|
|         | 1     |            |      | 0     | 1      | 1      | 1    | 0       | 0     | 0    | 1      | 1   | 1   | 0     | 0                 | 0     | 0     | 0    | 0   | 1               | 0                  |
| Micro-  | 2     | Со         | ntro | 1     | 0      | 0      | 0    | 0       | 0     | 1    | 0      | 0   | 0   | 1     | 0                 | 0     | 0     | 1    | 0   | 0               | 1                  |
| Program | 3     | W          | ord  | 0     | 0      | 0      | 0    | 1       | 1     | 0    | 0      | 0   | 0   | 0     | 0                 | 0     | 0     | 0    | 0   | 0               | 0                  |
|         | 4     |            |      | 0     | 0      | 1      | 1    | 0       | 0     | 0    | 0      | 0   | 0   | 0     | 0                 | 0     | 1     | 0    | 0   | 0               | 0                  |
|         | 5     |            |      |       |        |        |      |         |       |      |        |     |     |       |                   |       |       |      |     |                 |                    |
|         | 6     |            |      | 0     | 0      | 0      | 0    | 1       | 0     | 0    | 0      | 1   | 1   | 0     | 0                 | 0     | 0     | 0    | 0   | 1               | 0                  |
|         | 7     |            |      | 0     | 0      | 0      | 0    | 0       | 0     | 0    | 0      | 0   | 0   | 1     | 0                 | 1     | 0     | 0    | 1   | 0               | 0                  |

## **Class Exercise 10.2**

 Please fill in the missing control word in the below micro-program for the instruction ADD R1, (R3):



|                | Micro -<br>instruction | •• | PC in | PC out | MAR in | Read | MDR out | IR in | Y in | Select | bbd | Zin | Z out | R1 <sub>out</sub> | R1 in | R3out | WMFC | End | B <sub>in</sub> | MDR <sub>inE</sub> |
|----------------|------------------------|----|-------|--------|--------|------|---------|-------|------|--------|-----|-----|-------|-------------------|-------|-------|------|-----|-----------------|--------------------|
|                | 1                      |    | 0     | 1      | 1      | 1    | 0       | 0     | 0    | 1      | 1   | 1   | 0     | 0                 | 0     | 0     | 0    | 0   | 1               | 0                  |
|                | 2                      |    | 1     | 0      | 0      | 0    | 0       | 0     | 1    | 0      | 0   | 0   | 1     | 0                 | 0     | 0     | 1    | 0   | 0               | 1                  |
|                | 3                      |    | 0     | 0      | 0      | 0    | 1       | 1     | 0    | 0      | 0   | 0   | 0     | 0                 | 0     | 0     | 0    | 0   | 0               | 0                  |
| ontrol         | 4                      |    | 0     | 0      | 1      | 1    | 0       | 0     | 0    | 0      | 0   | 0   | 0     | 0                 | 0     | 1     | 0    | 0   | 0               | 0                  |
| ontrol<br>word | 5                      |    |       |        |        |      |         |       |      |        |     |     |       |                   |       |       |      |     |                 |                    |
|                | 6                      |    | 0     | 0      | 0      | 0    | 1       | 0     | 0    | 0      | 1   | 1   | 0     | 0                 | 0     | 0     | 0    | 0   | 1               | 0                  |
|                | 7                      |    | 0     | 0      | 0      | 0    | 0       | 0     | 0    | 0      | 0   | 0   | 1     | 0                 | 1     | 0     | 0    | 1   | 0               | 0                  |



# 2) Micro-programmed Control (Cont'd)

- A micro-program counter (uPC) is used to read control words sequentially from control store.
  - Whenever a new instruction is loaded into IR, "Starting Address Generator" loads the starting address into uPC.
  - 2 uPC increments by clock, causing successive microinstructions to be read out from the control store.
  - ③ Control signals are generated in the correct sequence defined by a micro-program21-22 T1



# 2) Micro-programmed Control (Cont'd)

- The previous scheme is not able to change the control sequence by other inputs.
  - It cannot support
     branch on condition
     code (e.g. Jump if < 0)</li>
- Starting and **branch** address generator:
  - Load new address into uPC when needed.
    - By checking condition codes or external inputs that can affect uPC.





### Outline



Control Signal Generation
1) Hard-wired Control
2) Micro-programmed Control

Machine Instruction Encoding

### **Machine Instruction Encoding**

- An instruction must be encoded in a compact binary pattern.
- The decoder must interpret (or decode) the instruction, and generate the control signals correctly.



Control signals



# Why Machine Instruction Encoding?



- We have a bunch of instructions:
  - Such as add, subtract, move, shift, rotate, branch, etc.
- Instructions may use operands of different sizes.
   Such as 32-bit and 8-bit number, or 8-bit ASCII characters.
- Both the type of operation and the type of operands need to be specified in encoded binary patterns.
  - Type of Operation: Often referred to as the OP code.
    - E.g., 8 bits can represent 256 different OP codes.
  - Type of Operands: Addressing modes.
    - An operand is the part of an instruction that specifies data to be operating on or manipulated.

### Example: 8051/8052 OP Code Map



|             |                 |                 |               |           |             |            |             |             | Lowerl      | Nibble     |            |            |            |            |           |            |           |
|-------------|-----------------|-----------------|---------------|-----------|-------------|------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|-----------|------------|-----------|
| OpCo        |                 |                 | 1             | 2         | 3           | 4          | 5           | 6           | 7           | 8          | 9          | Α          | В          | С          | D         | Е          | F         |
|             | NOF             | 2 A             | AJMP          | LJMP      | BB          | INC        | INC         | INC         | INC         | INC        | INC        | INC        | INC        | INC        | INC       | INC        | INC       |
|             |                 | P               | page0         | addr16    | A           | A          | iram        | @R0         | @R1         | R0         | B1         | R2         | R3         | R4         | R5        | R6         | - B7      |
|             |                 |                 |               |           |             |            |             |             |             |            |            |            |            |            |           |            |           |
|             | JBC             |                 | ACALL         | LCALL     | RRC         | DEC        | DEC         | DEC         | DEC         | DEC        | DEC        | DEC        | DEC        | DEC        | DEC       | DEC        | DEC       |
|             | bit,            |                 | page0         | addr16    | A           | A          | iram        | @R0         | @R1         | R0         | R1         | R2         | R3         | R4         | R5        | R6         | R7        |
|             | relad           |                 |               |           |             |            |             |             |             |            |            |            |            |            |           |            |           |
|             | JB              |                 | AJMP          | RET       | RL          | ADD        | ADD         | ADD         | ADD         | ADD        | ADD        | ADD        | ADD        | ADD        | ADD       | ADD        | ADD       |
| -           | 2 bit,          |                 | page1         |           | A           | Α,         | A,          | A,          | A,          | A,         | A,         | A,         | A,         | A,         | A,        | A,         | A,<br>DZ  |
|             | relad           |                 | CALL          | DETI      | DLC.        | #data      | iram        | @R0         | @R1         | RO         | B1         | R2         | R3         | R4         | R5        | R6         | B7        |
|             | JNE<br>3 bit.   |                 | ACALL         | RETI      | RLC<br>A    | ADDC<br>A, | ADDC        | ADDC        | ADDC        | ADDC<br>A, | ADDC<br>A, | ADDC<br>A, | ADDC       | ADDC<br>A, | ADDC      | ADDC       | ADDC      |
| -           | 3 bit,<br>relad |                 | page1         |           | A           | #data      | A,<br>iram  | A,<br>@R0   | A,<br>@R1   | R0         | B1         | R2         | A,<br>R3   | R4         | A,<br>R5  | A,<br>R6   | A,<br>B7  |
|             | JC              |                 | AJMP          | ORL       | ORL         | ORL        | ORL         | ORL         | ORL         | ORL        | ORL        | ORL        | ORL        | ORL        | ORL       | ORL        | ORL       |
|             | relad           |                 | page2         | iram,     | iram,       | A,         | A,          | A,          | A,          | A,         | A,         | A,         | A,         | A,         | A,        | A,         | A,        |
|             | - Telad         | -               | Jagez         | A         | #data       | #data      | iram        | @R0         | @R1         | RO         | - Rí       | R2         | R3         | R4         | R5        | R6         | B7        |
|             | JNC             |                 |               | ANL       | ANL         | ANL        | ANL         | ANL         | ANL         | ANL        | ANL        | ANL        | ANL        | ANL        | ANL       | ANL        | ANL       |
|             | s relad         |                 | page2         | iram,     | iram,       | Α,         | Α,          | Α,          | Α,          | Α,         | A,         | Α,         | Α,         | Α,         | Α,        | A,         | Α,        |
|             |                 |                 |               | A         | #data       | #data      | iram        | @R0         | @R1         | RÖ         | B1         | R2         | R3         | B4         | R5        | R6         | B7        |
|             | JZ              | - 4             | AJMP          | XRL       | XRL         | XRL        | XRL         | XRL         | XRL         | XRL        | XRL        | XRL        | XRL        | XRL        | XRL       | XRL        | XRL       |
|             | 6 relad         | dr p            | page3         | iram,     | iram,       | Α,         | Α,          | Α,          | Α,          | Α,         | Α,         | Α,         | Α,         | Α,         | Α,        | Α,         | Α,        |
|             |                 |                 | _             | A         | #data       | #data      | iram        | @R0         | @R1         | R0         | B1         | R2         | R3         | B4         | R5        | R6         | B7        |
| ole         | JNZ             | : A             | ACALL         | ORL       | JMP         | MOV        | MOV         | MOV         | MOV         | MOV        | MOV        | MOV        | MOV        | MOV        | MOV       | MOV        | MOV       |
| ldi         | 7 relad         | dr p            | page3         | C,        | @A+DPTR     | Α,         | iram,       | @R0,        | @R1,        | R0,        | B1,        | R2,        | R3,        | B4,        | R5,       | R6,        | B7,       |
| N           |                 |                 |               | bit       |             | #data      | #data       | #data       | #data       | #data      | #data      | #data      | #data      | #data      | #data     | #data      | #data     |
| er          | SJM             |                 | AJMP          | ANL       | MOVC        | DIV        | MOV         | MOV         | MOV         | MOV        | MOV        | MOV        | MOV        | MOV        | MOV       | MOV        | MOV       |
| Upper Nibbl | 3 relad         | dr p            | page4         | C,        | A,          | AB         | iram,       | iram,       | iram,       | iram,      | iram,      | iram,      | iram,      | iram,      | iram,     | iram,      | iram,     |
| n           |                 |                 |               | bit       | @A+PC       |            | iram        | @R0         | @R1         | RO         | R1         | R2         | R3         | R4         | R5        | R6         | R7        |
|             | MON             |                 | ACALL         | MOV       | MOVC        | SUBB       | SUBB        | SUBB        | SUBB        | SUBB       | SUBB       | SUBB       | SUBB       | SUBB       | SUBB      | SUBB       | SUBB      |
|             |                 |                 | page4         | bit,      | A,          | A,         | Α,          | A,          | A,          | A,         | A,         | A,         | A,         | A,         | A,        | A,         | A,        |
|             | #data           |                 | A 11 AD       | C         | @A+DPTR     | #data      | iram<br>222 | @R0         | @R1         | R0         | B1<br>MOV  | R2<br>MOV  | R3         | B4<br>MOV  | R5<br>MOV | R6         | B7<br>MOV |
|             | ORI<br>C,       |                 | AJMP<br>page5 | MOV<br>C, | INC<br>DPTR | MUL<br>AB  | ???         | MOV<br>@R0, | MOV<br>@R1, | MOV<br>R0, | B1,        | R2,        | MOV<br>R3, | R4,        | R5,       | MOV<br>R6, | B7,       |
| ,           | /bit            |                 | Jageo         | bit       | DEIN        | AD         |             | iram        | iram        | iram       | iram       | iram       | iram       | iram       | iram      | iram       | iram      |
|             | ANI             |                 |               | CPL       | CPL         | CJNE       | CJNE        | CJNE        | CJNE        | CJNE       | CJNE       | CJNE       | CJNE       | CJNE       | CJNE      | CJNE       | CJNE      |
|             | 3 C,            |                 | page5         | bit       | C           | A,         | A,          | @R0,        | @R1         | R0,        | B1,        | R2,        | R3,        | B4,        | R5,       | R6,        | B7,       |
|             | /bi             |                 | pageo         |           | Ŭ           | #data,     | iram,       | #data,      | #data,      | #data,     | #data,     | #data,     | #data,     | #data,     | #data,    | #data,     | #data,    |
|             | PUS             |                 | AJMP          | CLR       | CLR         | SWAP       | XCH         | XCH         | XCH         | XCH        | XCH        | XCH        | XCH        | XCH        | XCH       | XCH        | XCH       |
|             | iran            |                 | bage6         | bit       | С           | A          | Α,          | Α,          | Α,          | Α,         | Α,         | Α,         | Α,         | Α,         | Α,        | Α,         | Α,        |
|             |                 |                 | -             |           |             |            | iram        | @R0         | @R1         | R0         | B1         | R2         | R3         | B4         | R5        | R6         | B7        |
|             | POF             | 2 A             | ACALL         | SETB      | SETB        | DA         | DJNZ        | XCHD        | XCHD        | DJNZ       | DJNZ       | DJNZ       | DJNZ       | DJNZ       | DJNZ      | DJNZ       | DJNZ      |
|             | D iran          | • F             | page6         | bit       | C           | A          | iram,       | Α,          | Α,          | R0,        | B1,        | R2,        | R3,        | B4,        | R5,       | R6,        | B7,       |
|             |                 |                 |               |           |             |            | reladdr     | @R0         | @R1         | reladdr    | reladdr    | reladdr    | reladdr    | reladdr    | reladdr   | reladdr    | reladdr   |
|             | MOV             | $\times \mid A$ | AJMP          | MOVX      | MOVX        | CLR        | MOV         | MOV         | MOV         | MOV        | MOV        | MOV        | MOV        | MOV        | MOV       | MOV        | MOV       |
|             | E A,            |                 | page7         | Α,        | A,          | A          | Α,          | Α,          | A,          | Α,         | Α,         | Α,         | A,         | A,         | A,        | A,         | A         |
|             | @DP1            |                 |               | @R0       | @R1         |            | iram        | @R0         | @R1         | R0         | R1         | R2         | R3         | R4         | R5        | R6         | R7        |
|             | MOV             |                 | ACALL         | MOVX      | MOVX        | CPL        | MOV         | MOV         | MOV         | MOV        | MOV        | MOV        | MOV        | MOV        | MOV       | MOV        | MOV       |
|             | = @DPT          | 8, p            | page7         | @R0,      | @R1,        | A          | iram,       | @R0,        | @R1,        | R0,        | B1,        | R2,        | R3,        | R4,        | R5,       | R6,        | B7,       |
|             | A               |                 |               | A         | A           |            | A           | A           | A           | A          | A          | A          | A          | A          | A         | A          | A         |

# **One-word Instruction (1/2)**



• Some instructions can be encoded in one 32-bit word:

| 8       | 3+4    | 3+4  | 10         |
|---------|--------|------|------------|
| OP code | Source | Dest | Other info |

- **OP code**: 8 bits
- Src and Dest: 3 bits (addressing mode) + 4 bits (register #)
- Other info: 10 bits (such as index value)
- ADD R1, R2
  - Needs to specify OP code, SRC and DEST registers.
    - 8 bits for OP code.
    - 3 bits are needed for addressing modes.
    - 4 bits are required to distinguish 16 registers.

- MOV R5, 24(R0)
  - Needs to specify OP code, two registers and an index value of 24.
    - 10 bits of other info can be used for the index value.

## **One-word Instruction (2/2)**



• Some instructions can be encoded in one 32-bit word:

| 8       | 24             |
|---------|----------------|
| OP code | Branch address |

- **OP code**: 8 bits
- Branch address: 24 bits
- Branch>0 Offset
  - 8 bits for OP code
  - 24 bits are left for the branch address.

#### **Question: How can we branch farther away?**

## **Two-word Instruction**



 What if we want to specify a memory operand using the <u>absolute addressing mode</u>?

#### MOV R2, LOC

- 8 bits for OP code, 3+4 bits for addressing mode and register number for R2, 3 bits for addressing mode for LOC.
- Only 14 bits left for specifying the memory address.
- Some instructions need an additional word to contain the absolute memory address or an immediate value:

| OP code | Source                             | Dest | Other info |  |  |  |  |  |
|---------|------------------------------------|------|------------|--|--|--|--|--|
| Memo    | Memory address / Immediate operand |      |            |  |  |  |  |  |

- E.g., Add R2, FF00000<sub>h</sub> (immediate operand)

# Multi-word Instruction (1/2)



 What if we want to allow an instruction in which both two operands can be specified using the <u>absolute</u> <u>addressing mode</u>?

#### MOV LOC1, LOC2

 It becomes necessary to use two additional words for the 32-bit addresses of the two operands ...

| OP code                            | Source       | Dest        | Other info |  |  |  |  |
|------------------------------------|--------------|-------------|------------|--|--|--|--|
| Memory address / Immediate operand |              |             |            |  |  |  |  |
| Memo                               | ry address , | / Immediate | e operand  |  |  |  |  |

# Multi-word Instruction (2/2)



- If we allow instructions using two 32-bit direct address operands, we need three words in total for the instruction encoding scheme.
  - E.g., MOV LOC1, LOC2
- Multiple length instructions are difficult to implement with high clock rate.
  - The design of the Instruction Register (IR) and the Instruction Decoder will be complex.
  - The Control Unit will be difficult to design.
- Shall we go for simple or complex?

## **Recall: RISC vs. CISC Styles**



| RISC                                                                                                                                  | CISC                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Simple addressing modes                                                                                                               | More complex addressing modes                                                                                                      |
| All instructions fitting in a single word                                                                                             | More complex instructions, where an instruction may span multiple words                                                            |
| Fewer instructions in the instruction set, and simpler addressing modes                                                               | Many instructions that implement complex tasks, and complicated addressing modes                                                   |
| Arithmetic and logic operations that can be performed only on operands in processor registers                                         | Arithmetic and logic operations that can be performed on memory and register operands                                              |
| Don't allow direct transfers from one<br>memory location to another<br>Note: Such transfers must take place via a processor register. | Possible to transfer from one memory<br>location to another by using a single Move<br>instruction                                  |
| Programs that tend to be larger in size,<br>because more but simpler instructions are<br>needed to perform complex tasks              | Programs that tend to be smaller in size,<br>because fewer but more complex<br>instructions are needed to perform<br>complex tasks |
| Simple instructions that are conducive to fast execution by the processing unit using techniques such as pipelining                   |                                                                                                                                    |

## **CISC vs RISC**



#### • CISC OR RISC?

- CISC machines usually require less instructions to do something but have a lower clock rate …
- RISC machines require more instructions to do something but have a higher clock rate...
- The Best of Both World: CISC WITH RISC
  - Modern processors usually combine the strengths of both CISC and RISC.
  - E.g., a CISC design with a RISC core:
    - Design a RISC-style core instruction decoder with high clock rates.
    - Provide <u>a rich set</u> of CISC-style instructions and addressing modes to assembly programmers.

## Summary



- Control Signal Generation
  - 1) Hard-wired Control
  - 2) Micro-programmed Control

Machine Instruction Encoding